<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>

<body>
    <div id="app">
        <!-- 
            插槽分为匿名插槽/具名插槽/作用域插槽
            插槽的作用时我们可以给组件预留空间给用户自己定义内容
            <slot></slot>不写name属性时的使用方法就叫匿名插槽
            可以通过v-slot:插槽的名字给指定的插槽定义内容 v-slot:可以简写为#
            其时所谓的匿名插槽是有名子的 他的名字是default
            插槽也可以通过自定义属性预备插槽需要使用的数据 而这种插槽就叫做作用域插槽
         -->
        <com>
            <template #default>
                <div>德玛西亚</div>
            </template>
            <template v-slot:h>
                <div>犯我德邦者,虽远必诛</div>
            </template>
            <template #z>
                <div>一点寒芒先到,随后枪出入龙</div>
            </template>
            <template #z="{say1, say2}">
                <div>{{say1}}</div>
            </template>
        </com>
    </div>
    <script src="./js/vue.js"></script>
    <script>
        const com = {
            data() {
                return {
                    say1: '一点寒芒先到,随后枪出入龙',
                    say2: 'good good study'
                }
            },
            template: `
                <div>
                    <div>盖盖</div>
                    <slot></slot>
                    <div>皇皇</div>
                    <slot name="h"></slot>
                    <div>菊菊</div>
                    <slot name="z" :say1="say1" :say2="say2"></slot>
                </div>
            `
        }
        new Vue({
            el: "#app",
            components: {
                com
            }
        })
    </script>
</body>

</html>